

F19 - Theory of Operation Apple Confidential



F19 - Theory of Operation Apple Confidential







F19 - Theory of Operation Apple Confidential





F19 - Theory of Operation Apple Confidential

Read - RAM Address pointer high byte.

Write - RAM Address pointer high byte.



Bits A15:A8 - These bits form the high address of the 16 - bit host processor pointer to shared RAM. After each host processor access to RAM the Address pointer will increment by one.



Read - Status/Control register.

Write - Status/Control register.



Bit D0 - is a read only bit which reflects the state of the PIC BYPASS signal. When this bit is set the host controls the peripheral port.

Bit D1 - INCEN is used to control the incrementing of the host address pointer. When this bit is set the host address pointer increments after each RAM access. Resetting this bit disables the auto-increment feature and causes the pointer to maintain a constant address during sequential RAM cycles.

Bit D2 - /RSTPIC is used to reset the peripheral interface controller. This bit is forced active by a system reset.

Bit D3 - INTPIC allows the host processor to interrupt the peripheral processor. This bit is asynchronously cleared by the peripheral processor.

Bits D5:D4 - The peripheral processor uses these bits to create host interrupt requests with different priority levels. The host processor can asynchronously clear these interrupts by storing a "1" to the respective bit. Storing a zero will leave the bit state unchanged.

Bit D6 - PINT is the peripheral port interrupt signal. It is used in the bypass mode only. In the non-bypass mode this signal is inactive.

Bit D7 - /REQ is low if either of the DMA request signals is active. It is used in the bypass mode only. When the PIC is in the non-bypass mode the /REQ signal is in its inactive state.

Address Offset \$4 Read - Ram Data. Write - Ram Data.



Address locations \$10-1F are allocated to device registers. These registers are accessible by the host processor only in the bypass mode of operation.

## Device

| Address                                            | SCC                                                        | SWIM                                                                                                                              |
|----------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18 | SCC B Command<br>SCC A Command<br>SCC B Data<br>SCC A Data | Write Data Write Mark Write CRC Write Parameter RAM Write Phase Write Setup Write Mode Zeroes Write Mode Ones Read Data Read Mark |
| 1A<br>1B<br>1C<br>1D<br>1E<br>1F                   |                                                            | Read Error Read Parameter RAM Read Phase Read Setup Read Status Read Handshake                                                    |



F19 - Theory of Operation Apple Confidential

Read - Timer low counter, reset timer interrupt.

Write - Timer low latch.

Timer low order counter

## Address Offset \$11

Read - Timer high counter.

Write - Timer High latch, load counters, reset timer interrupt.

Timer high order counter

## Address Offset \$12

Read - Timer low latch.

Write - Timer low latch.

Timer low order latch

## Address Offset \$13

Read - Timer high latch.

Write - Timer high latch.

Timer high order latch

Write - DMA channel 1 control. D<sub>6</sub> D7 **D5** D4 **D3** D2 D1 D0 DMAEN1. 0 - disable DMA channel 1 - enable DMA channel DREQ1, 0 - DMA request 1 inactiv 1 - DMA request 1 active 0 - transfer RAM to I/O DMADIR1, 1 - transfer I/O to RAM DEN1ON2, 0 - inactive 1 - start DMA 1 after DM/ complete IOA1(0:3), - DMA I/O address Bit/D0 - DMAEN1 enables DMA channel 1 for transfers. Bit Q1 - DREQ1/refleats the state of the DMA request line for channel 1 Bit D2 - DMADIA controls the direction of the DMA transfer. When DMADIR is low data is read from RAM and written to the SCC/SWIM. When DMADIR is high data is read from the SCC/8WIM and written to RAM. Bit D3 - DEN1ON2 when set will automatically enable DMA channel 1 at the completion of a transfer over DMA channel 2. These bits define the SCC/SWIM address used during the DMA cycle.

Address Offset \$20

Read - DMA channel 1 control.

Read - DMA channel 1 RAM address pointer low byte. Write - DMA channel 1 RAM address pointer low byte.



Bits A7:A0 - These bits form the low address of the 16 - bit DMA pointer to RAM. After each DMA access to RAM the Address pointer will increment by one.

### Address Offset \$22

Read - DMA channel 1 RAM address pointer high byte. Write - DMA channel 1 RAM address pointer high byte.



Bits A15:A8 - These bits form the high address of the 16 - bit DMA pointer to RAM. After each DMA access to RAM the Address pointer will increment by one.

Read - DMA channel 1 transfer count low byte.

Write - DMA channel 1 transfer count low byte.



Bits A7:A0 - These bits form the low byte of the 11-bit DMA transfer count register. After each DMA cycle the transfer count decrements by one. When the transfer count reaches zero the DMA interrupt bit is set and further DMA requests are disabled.



Bits A10:A8 These bits form the high byte of the 11-bit DMA transfer count register. After each DMA cycle the transfer count decrements by one. When the transfer count reaches zero the DMA interrupt bit is set and further DMA requests are disabled.

Read - DMA channel 2 control.

Write - DMA channel 2 control.



Bit D0 - DMAEN2 enables DMA channel 2 for transfers.

Bit D1 - DREQ2 reflects the state of the DMA request line for channel 2.

Bit D2 - DMADIR controls the direction of the DMA transfer. When DMADIR is low data is read from RAM and written to the SCC/SWIM. When DMADIR is high data is read from the SCC/SWIM and written to RAM.

Bit D3 - DEN2ON1 when set will automatically enable DMA channel 2 at the completion of a transfer over DMA channel 1.

Bits D7:D4 - These bits define the SCC/SWIM address used during the DMA cycle.

Read - DMA channel 2 RAM address pointer low byte.

Write - DMA channel 2 RAM address pointer low byte.



Bits A7:A0 - These bits form the low address of the 16 - bit DMA pointer to RAM. After each DMA access to RAM the Address pointer will increment by one.



Read - DMA channel 2 transfer count low byte.

Write - DMA channel 2 transfer count low byte.



Bits A7:A0 - These bits form the low byte of the 11-bit DMA transfer count register. After each DMA cycle the transfer count decrements by one. When the transfer count reaches zero the DMA interrupt bit is set and further DMA requests are disabled.

### Address Offset \$2C

Read - DMA channel 2 transfer count high byte.

Write - DMA channel 2 transfer count high byte.



Bits A10:A8 - These bits form the high byte of the 11-bit DMA transfer count register. After each DMA cycle the transfer count decrements by one. When the transfer count reaches zero the DMA interrupt bit is set and further DMA requests are disabled.

Read - SCC control register.

Write - SCC control register.





Bits D6:D5 - these bits represent an encoded value used to multiplex one of four clock sources onto the RTXCB signal. A table listing the clock sources is given below.

| RTXCB source                     |  |
|----------------------------------|--|
| 3.6864MHz                        |  |
| DPCLK/10                         |  |
| Digital phase locked loop output |  |
| GPIB                             |  |
|                                  |  |

Bit D7 - GPOUT1 controls the state of general purpose output 1.

## Address Offset \$31

Read - I/O Control register

Write - I/O Control register.



Bits D3:D0 - These bits are used to program the duration of the SCC/SWIM chip-select. The chip-select duration is equal to the count+1 multiplied by the IOCLK period. These bits are set after a system reset.

Bits D7:D4 - These bits are used to program the holdoff interval between sequential SCC/SWIM accesses. The holdoff delay is equal to the count multiplied by twice the IOCLK period. These bits are set after a system reset.

Read - Timer/DPLL control.

Write - Timer/DPLL control.



Bit DO - This bit selects between the one-shot mode and continuous mode of timer operation. In the one-shot mode the timer interrupt bit is set when the cou reaches zero. After counting to zero the timer underruns and continues to count further interrupts are disabled. In the continuous mode the timer generales interru spaced at constant time intervals.

Bit D1 - GPOUT0 controls general purpose output A

Bit D2 - GPINO reflects the state of general purpose input 0.

Bit D3 - GPIN1 reflects the state of general purpose input 1.

Bit D4 - DPLL1EN forces the DPLL for channel A to begin searching for clock information on the RXDA signal source. Clock information is recovered at a frequency of DPCLK/10 and output on the RTXCA signal line. The RTXCA clock signal is \$ degrees out of phase with the RXDA transition information in order to permit the PIC to recover FM0 data from the receive signal. The recovered data is placed on the RXDAO output in NRZ format.

Bit D5 - CRSNS1 is valid whenever clock activity is detected on the RXDA sign? CRSNS1 is reset if clock activity is absent for more than 128 DPCLK cycles.

Bit D6 - DPLL2EN forces the DPLL for channel B to begin searching for clock information on the RXDB signal source. Clock information is recovered at a frequer of DPCLK/10 and output on the RTXCB signal line. The RTXCB clock signal is 90 degrees out of phase with the RXDB transition information in order to permit the SCC to recover FM0 data from the receive signal. The recovered data is placed on the RXDBO output in NRZ format.

Bit D7 - CRSNS2 is valid whenever clock activity is detected on the RXDB signal. CRSNS2 is reset if clock activity is absent for more than 128 DPCLK cycles.

#### Address Offset \$33

Read - Interrupt mask register.

Write - Interrupt mask register.



- Bit D1 DMA1ENI disables interrupts from DMA channel 1.
- Bit D2 DMA2ENI disables interrupts from DMA channel 2.
- Bit D3 PERENI allows the peripheral processor to disable interrupts from the peripheral port.
- Bit D4 HSTENI allows the peripheral processor to disable interrupts from the host processor.
- Bit D5 TMRENI disables interrupts from 16-bit timer.

Read - Interrupt register.

Write - Interrupt register.



Bit D1 - DMA1INT is set at the end of a DMA transfer. This bit can be reset by storing a "1" to it. Storing a zero will leave the bit state unchanged.

Bit D2 - DMA2INT) is set at the end of a DMA transfer. This bit can be reset by storing a "1" to it. Storing a zero will leave the bit state unchanged.

Bit D3 - PINT menitors the state of the peripheral interrupt request line. In the BYPASS mode of operation this bit is disabled and in its inactive state.

Bit D4 HSTINT Indicates that the host processor has requested interrupt service. This bit can be reset by storing a "1" to it. Storing a zero will leave the bit state unchanged.

Bit D5 - TMRINT reflects the state of the timer interrupt request output. This bit can be reset by storing a "1" to it or by reading the timer low order counter. Storing a zero will leave the bit state unchanged.

Address Offset \$35 Read - Host register.

Write - Host register.



Bits D3:D2 - Storing a "1" to either of these bits will generate a host processor interrupt. These bits are asynchronously cleared by the host processor.

# Peripheral Processor I/O map

Base address \$F000

Address locations \$40-4F are allocated to device registers. These registers are accessible by the peripheral processor only in the non-bypass mode of operation.

## Device

| Address                                                                                      | SCC                                                        | SWIM                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>4A<br>4B<br>4C<br>4D<br>4E<br>4F | SCC B Command<br>SCC A Command<br>SCC B Data<br>SCC A Data | Write Data Write Mark Write CRC Write Parameter RAM Write Phase Write Setup Write Mode Zeroes Write Mode Ones Read Data Read Mark Read Error Read Parameter RAM Read Phase Read Setup Read Status Read Handshake |

F19 - Theory of Operation Apple Confidential